IModel.AddNewModel メソッド

名前空間: NextDesign.Core

説明

このインスタンスの指定されたフィールドに指定されたクラスのインスタンスをフィールド値として追加します。
インスタンスが、該当フィールドの末尾の要素として追加されます。
指定されたクラスが抽象クラスの場合でもインスタンス化を許容し、該当フィールドの末尾の要素として追加されます。
指定するフィールドは、クラス型の所有フィールドでなければなりません。
多重度が2以上のフィールドの多重度上限制約に違反しても例外はスローされません。

また、指定するクラス名は、フィールドのデータ型と互換する型を指定する必要があります。
なお、あいまい一致とするときに、一致するクラスが複数ある場合、一番最初に見つかった型互換のあるクラスのインスタンスを追加します。

引数

名前 説明
fieldName string フィールド名
null、または空文字列は指定できません。
className string クラス名
クラスの名前、または完全修飾名を指定します。
null、または空文字列は指定できません。
fuzzy bool className引数を、完全修飾名ではなくクラスの名前として扱うかどうか。
Falseの場合、完全修飾名がclassNameに一致するクラスを指定したものとして評価します。
Trueの場合、クラス名がclassNameに一致するクラスを指定したものとして評価します。

既定値はTrueです。

戻り値

例外

名前 例外クラス 説明
引数不正 ExtensionArgumentException fieldName 、または className に null または空文字列を指定した場合
フィールドが見つからない ExtensionFieldNotFoundException 指定されたフィールドがこのインスタンスのメタクラスで見つからない場合
指定フィールド不正 ExtensionInvalidTypeException 指定されたフィールドに設定できない値が指定された場合
- 指定されたフィールドが所有フィールドでない
- 指定されたフィールドのデータ型がクラス型でない
- 指定されたフィールドの型と指定されたクラスが互換しない
クラスが見つからない ExtensionTypeNotFoundException 指定されたクラスが見つからない場合
不正操作 ExtensionInvalidOperationException 自身が削除済みモデル、一時プロキシの場合
フィールド名に操作不可のフィールドが指定された場合
- プロダクトラインのフィーチャ割り当てフィールド
- System.Coreタグが付与されているフィールド